# CSU22022 Computer Architecture I

### Prof. Michael Manzke

Processor Assignment: Project Milestone Register File

### Simulation Procedure

20<sup>th</sup> October 2022

#### Version 1.0

The Schematic 1 on the following page depicts the register file that you need to implement. You need to build a project in Vivado to run simulations and generate schematics for all entities of the assignment.

You Vivado project should be named "RegisterFile\_32\_15\_XXXXXXXX", with XXXXXXXX as your student number. The entity name follows the same convention, please see Table 1.

The project requires the following entities Please see Table 1 below and Schematic 1 on the following page  $SSIgnment\ Project\ Exam\ Help$ 

| Number of Instantiations |                                                   |                                     |
|--------------------------|---------------------------------------------------|-------------------------------------|
|                          | Instantiation Notetps://powcoder.com              |                                     |
|                          | пщь                                               | ://powcoder.com                     |
|                          |                                                   |                                     |
| 1                        | TestRegFile \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | RE Tasi Revister File 22-15-XXXXXXX |
| _                        | Ada                                               | Weethatiepowcoder                   |
| 1                        | RegFile                                           | RF_RegisterFile_32_15_XXXXXXXX      |
|                          |                                                   |                                     |
| 1                        | DestReg_Decoder                                   | RF_DestReg_Decoder_XXXXXXXX         |
|                          |                                                   |                                     |
| 1                        | DestTempReg_Decoder                               | RF_TempDestReg_Decoder_XXXXXXXX     |
|                          |                                                   |                                     |
| 32                       | RegisterXX, XX=00 to 31                           | RF Register32Bit XXXXXXXX           |
| 15                       | TempRegXX, XX=01 to 15                            | NI_Negister32bit_AAAAAAA            |
|                          |                                                   |                                     |
| 1                        | Mux32_A                                           | RF_Mux32_32Bit_XXXXXXXX             |
| 1                        | Mux32_B                                           | TII_IVIUX32_32BIL_XXXXXXXX          |
|                          |                                                   |                                     |
| 1                        | Mux16_A                                           | RF_Mux16_32Bit_XXXXXXXX             |
| 1                        | Mux16_B                                           | III_IVIGATO_32BIL_XXXXXXXX          |
|                          |                                                   |                                     |
| 1                        | Mux3                                              | RF_Mux3_32Bit_XXXXXXXX              |
|                          |                                                   |                                     |

Table 1



Schematic 1 depicts the register file with all entities and the enable logic for the Registers and Temp Registers

You must provide the following for every entity:

- 1. Design code e.g. RF\_RegisterFile\_32\_15\_XXXXXXXX.vhd
- 2. A test bench e.g. RF\_RegisterFile\_32\_15\_XXXXXXXX\_TB.vhd
- 3. One or more schematics e.g. RF\_RegisterFile\_32\_15\_XXXXXXX\_SchematicXX.jpg
- 4. As many as needed annotated e.g. timing diagrams RF\_RegisterFile\_32\_15\_XXXXXXXX\_TDXX.jpg
- 5. Simulation Procedure documentation RF RegisterFile 32 15 XXXXXXXX Doc.jpg

## Simulation Procedure for the following entities:

### RF\_Mux3\_32Bit\_XXXXXXXX

Convert your student ID into binary and set:

IN00 = student ID IN01 = student ID + 1 IN02 = student ID + 2

Demonstrate that the multiplexer functions correctly.

### RF\_Mux16\_32Bit\_XXXXXXXX

Convert your student ID into binary and set:

IN00 = student ID IN01 = student ID + 1 IN02 = student ID + 2 continue for all inputs

Demonstrate Siegnment of Peroject Exam Help

# RF\_Mux32\_32Bit\_xxxxxxxx/powcoder.com

Convert your student ID into binary and set:

IN00 = student ID Add WeChat powcoder IN01 = student ID + 1 Add WeChat powcoder IN02 = student ID + 2

continue for all inputs

Demonstrate that the multiplexer functions correctly.

### RF\_Register32Bit\_XXXXXXXX

Convert your student ID into binary. Write and read the register with your ID.

Demonstrate that the register functions correctly.

### RF\_DestReg\_Decoder\_XXXXXXXX

Demonstrate that the decoder functions correctly.

### RF\_TempDestReg\_Decoder\_XXXXXXXX

Demonstrate that the decoder functions correctly.

### RF\_RegisterFile\_32\_15\_XXXXXXXX

In addition to an overview schematic, you must provide zoom in screenshots that allow me to read the entity names. The following screenshots is an example:



Convert your student ID into binary and set:

Load registers as follows:

Register00 = student ID

Register01 = student ID + 1

Register02 = student ID + 2

continue for all Registers (32+15) including the Temp Registers.

Read all registers and confirm that the functions correctly.

#### RF\_Test\_RegisterFile\_32\_15\_XXXXXXXX



Load registers via RF\_Mux3\_32Bit\_XXXXXXXX:

Register00 = student ID

Register01 = student ID + 1

Register02 = student ID + 2

continue for all Registers (32+15) including the Temp Registers.

Read all registers and confirm that the functions correctly.

Perform 4 register transfer operations on the Port A (A[31:1]) and 4 register transfer operations on the Port B (B[31:1]).

All files must be submitted to Blackboard as individual files, no zip files. Submit only entities that are working and are fully tested. You must follow the entity order on the checklist. You cannot skip entities. You must also submit the Checklist "CSU22022 Project Milestone Register File 2022-2023 Checklist V1.1"